博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django的Rbac介绍3
阅读量:6237 次
发布时间:2019-06-22

本文共 2822 字,大约阅读时间需要 9 分钟。

今天的博客主要是记录一下如何实现左侧菜单,这里我们想实现的效果就是,如果用户有查看用户的权限,则显示查看用户的左侧菜单,如果用户有查看角色的权限,则显示查看角色的左侧菜单,如果两者都有,则需要显示两个菜单

我们先来看下model中我们如何设计的数据库

from django.db import models# Create your models here.class Userinfo(models.Model):    username = models.CharField(max_length=64)    uerpwd = models.CharField(max_length=64)    roles = models.ManyToManyField(to="Role")    def __str__(self):        return self.username    class Meta:        verbose_name = "用户表"        verbose_name_plural = verbose_nameclass Role(models.Model):    title = models.CharField(max_length=64)    pers = models.ManyToManyField(to="per")    def __str__(self):        return self.title    class Meta:        verbose_name="角色表"        verbose_name_plural = verbose_nameclass per(models.Model):    title = models.CharField(max_length=64)    url = models.CharField(max_length=128)    action = models.CharField(max_length=32, default="")    group = models.ForeignKey("PerGroup", default=1)    def __str__(self):        return self.title    class Meta:        verbose_name = "权限表"        verbose_name_plural = verbose_nameclass PerGroup(models.Model):    title = models.CharField(max_length=32)    def __str__(self): return self.title    class Meta:        verbose_name = "权限组"        verbose_name_plural = verbose_name

  

 

在视图函数中,我们可以在session中拿到per_dict这个数据,下面的数据就是某个用户的per_dict的值

这个数据的内容如下

{'1':

'urls': ['/user/', '/user/add/', '/user/edit/(\\d+)', '/user/del/(\\d+)'],

'action': ['list', 'add', 'edit', 'del']},
'2':
{
'urls': ['/role/add/', '/role/', '/role/del/(\\d+)','/role/edit/(\\d+)'],
'action': ['add', 'list', 'del', 'edit']}}

 

我们需要拿到action为list的权限,并拿到这个这个权限的titile和url,代码如下

 

先获取per_group的列表

group_list = []    for k,v in request.session["per_dict"].items():        if "list" in v["action"]:            group_list.append(k)

  

通过per_group的列表,获取title和url,然后渲染到前端就可以了

menu_tile = []    print(group_list,"ddddddddddddddddddddddd")    from django.db.models import Q    for i in group_list:        name = rbacmodels.PerGroup.objects.get(id=int(i)).title        url = rbacmodels.PerGroup.objects.get(id=int(i)).per_set.filter(Q(action__exact="list")).first().url        temp = [name,url]        menu_tile.append(temp)

  

return render(request,"rbac_roles.html",{"action":action,"role_list":role_list,"menu_tile":menu_tile})

  

最后在html文件中渲染就可以了

  

 

 

上面的html这里的代码处理,我们是不是还有更加方便的实现手段,当然有,因为这里其实就是一个html的片段,我们可以用使用inclusion_tags来实现

下面我们就用inclusion_tags来实现

 

 这个函数的意思就是,将函数的返回值,渲染到inclusion_tags中指定的html文件中

 

我们在看下渲染的html文件

  

最后我们看下调用这个函数的html文件

{% load rbac_tags %}{% create_rbac_menu  menu_tile %}

  

这里要非常注意,使用inclusion_tags传参不需要"|"来进行传参

 

转载于:https://www.cnblogs.com/bainianminguo/p/10023894.html

你可能感兴趣的文章
Linux—yum环境的三种搭建方法
查看>>
Windows Server 2016-命令行批量导出AD用户信息
查看>>
Spring Security 过滤流程
查看>>
Vue transition源码浅析
查看>>
如何提升团队的研发效率?来听听阿里研发专家是怎么说的
查看>>
Django-关于manage.py migrate无效的问题
查看>>
eclipse maven创建web工程2.0转3.0
查看>>
FTP 服务器上传文件 553 Could not create file
查看>>
this的用法
查看>>
windows下安装redis
查看>>
CentOS7 yum 安装git
查看>>
启动日志中频繁出现以下信息
查看>>
httpd – 对Apache的DFOREGROUND感到困惑
查看>>
分布式锁的一点理解
查看>>
idea的maven项目,install下载重复下载本地库中已有的jar包,而且下载后jar包都是lastupdated问题...
查看>>
2019测试指南-web应用程序安全测试(二)指纹Web服务器
查看>>
树莓派3链接wifi
查看>>
js面向对象编程
查看>>
Ruby中类 模块 单例方法 总结
查看>>
jQuery的validate插件
查看>>